gint offset,
gint *index);
static void gtk_tree_model_filter_remove_node (GtkTreeModelFilter *filter,
- GtkTreeIter *iter);
+ FilterLevel *level,
+ FilterElt *elt);
static void gtk_tree_model_filter_update_children (GtkTreeModelFilter *filter,
FilterLevel *level,
FilterElt *elt);
static void
gtk_tree_model_filter_remove_node (GtkTreeModelFilter *filter,
- GtkTreeIter *iter)
+ FilterLevel *level,
+ FilterElt *elt)
{
- FilterElt *elt, *parent;
- FilterLevel *level, *parent_level;
+ FilterElt *parent;
+ FilterLevel *parent_level;
gint i, length, parent_elt_index;
+ GtkTreeIter iter;
gboolean emit_child_toggled = FALSE;
- level = FILTER_LEVEL (iter->user_data);
- elt = FILTER_ELT (iter->user_data2);
+ iter.stamp = filter->priv->stamp;
+ iter.user_data = level;
+ iter.user_data2 = elt;
parent_elt_index = level->parent_elt_index;
if (parent_elt_index >= 0)
if (elt->children)
gtk_tree_model_filter_free_level (filter, elt->children, TRUE);
- path = gtk_tree_model_get_path (GTK_TREE_MODEL (filter), iter);
+ path = gtk_tree_model_get_path (GTK_TREE_MODEL (filter), &iter);
elt->visible = FALSE;
gtk_tree_model_filter_increment_stamp (filter);
- iter->stamp = filter->priv->stamp;
+ iter.stamp = filter->priv->stamp;
gtk_tree_model_row_deleted (GTK_TREE_MODEL (filter), path);
gtk_tree_path_free (path);
while (elt->ref_count > 1)
gtk_tree_model_filter_real_unref_node (GTK_TREE_MODEL (filter),
- iter, FALSE);
+ &iter, FALSE);
if (parent_level || filter->priv->virtual_root)
- gtk_tree_model_filter_unref_node (GTK_TREE_MODEL (filter), iter);
+ gtk_tree_model_filter_unref_node (GTK_TREE_MODEL (filter), &iter);
else if (elt->ref_count > 0)
gtk_tree_model_filter_real_unref_node (GTK_TREE_MODEL (filter),
- iter, FALSE);
+ &iter, FALSE);
/* remove the node */
tmp = bsearch_elt_with_offset (level->array, elt->offset, &i);
elt->children = NULL;
}
- path = gtk_tree_model_get_path (GTK_TREE_MODEL (filter), iter);
+ path = gtk_tree_model_get_path (GTK_TREE_MODEL (filter), &iter);
elt->visible = FALSE;
gtk_tree_model_filter_increment_stamp (filter);
gtk_tree_model_row_deleted (GTK_TREE_MODEL (filter), path);
/* Blow level away, including any child levels */
- path = gtk_tree_model_get_path (GTK_TREE_MODEL (filter), iter);
+ path = gtk_tree_model_get_path (GTK_TREE_MODEL (filter), &iter);
elt->visible = FALSE;
gtk_tree_model_filter_increment_stamp (filter);
- iter->stamp = filter->priv->stamp;
+ iter.stamp = filter->priv->stamp;
gtk_tree_model_row_deleted (GTK_TREE_MODEL (filter), path);
gtk_tree_path_free (path);
while (elt->ref_count > 1)
gtk_tree_model_filter_real_unref_node (GTK_TREE_MODEL (filter),
- iter, FALSE);
+ &iter, FALSE);
gtk_tree_model_filter_free_level (filter, level, TRUE);
}
level = FILTER_LEVEL (iter.user_data);
level->visible_nodes--;
- gtk_tree_model_filter_remove_node (filter, &iter);
+ gtk_tree_model_filter_remove_node (filter, level,
+ FILTER_ELT (iter.user_data2));
goto done;
}
*/
level->visible_nodes--;
- gtk_tree_model_filter_remove_node (filter, &iter);
+ gtk_tree_model_filter_remove_node (filter, level, elt);
return;
}